/* ---------------------------------------------------------------
	入力フォーム
--------------------------------------------------------------- */

.sn-m-form fieldset, .sn-m-form legend, .sn-m-form label, .sn-m-form input{
	max-width: 100%;
	box-sizing:border-box;
}
.sn-m-form fieldset {
	border: none;
	padding: 0;
	margin: 8px 0;
}
.sn-m-form legend {
	font-size: 16px;
	font-weight: bold;
	margin: 16px 0 0 0;
	display: inline-block;
}
.sn-m-form legend > span {
	font-size: 12px;
}
.sn-m-form label{
	display: inline-block;
	vertical-align: text-top;
}
.sn-m-form label sup{
	display: block;
	margin:0 8px;
}
.sn-m-form .sn-m-form-fieldset-inner {
	margin: 8px 16px;
}
/*必須*/
.sn-m-form .sn-p-required:after {
	content: "[必須]";
	color: #bb0000;
	display: inline-block;
	font-size: 12px;
	font-weight: bold;
	margin-left: 4px;
}
/*ラジオボタン*/
.sn-m-form ul.sn-m-form-fieldset-inner {
	list-style: none;
}
.sn-m-form ul.sn-m-form-fieldset-inner + ul.sn-m-form-fieldset-inner {
	margin-top: -8px;
}
.sn-m-form ul.sn-m-form-fieldset-inner li {
	display: inline-block;
	padding: 2px 0;
	margin: 0;
}
.sn-m-form .sn-m-form-fieldset-inner.sn-d-multicolumn2 li, .sn-m-form .sn-m-form-fieldset-inner.sn-d-multicolumn3 li, .sn-m-form .sn-m-form-fieldset-inner.sn-d-multicolumn4 li {
	display: block;
}
/*テーブルレイアウト*/
.sn-m-form-table {
	box-sizing: border-box;
	margin: 16px auto;
}
.sn-m-form-table fieldset {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
.sn-m-form-table fieldset > span, .sn-m-form-table .sn-m-form-fieldset-inner {
	margin: 0;
	padding: 8px;
	box-sizing: border-box;
}
.sn-m-form-table fieldset > span {
	background: #fafafa;
}
.sn-m-form-table fieldset > span > legend{
	margin: 0;
}
.sn-m-form-table legend > span {
	display: block;
}

/*PC*/
@media screen and (min-width: 768px) {
.sn-m-form-table {
	display: table;
	width: 678px;
	table-layout: fixed;
	border-collapse: collapse;
	border-top: 1px solid #888;
}
.sn-m-form-table fieldset {
	display: table-row;
}
.sn-m-form-table .sn-m-form-fieldset-inner {
	width: 468px;
}
.sn-m-form-table fieldset > span {
	width: 210px;
}
.sn-m-form-table fieldset > span, .sn-m-form-table .sn-m-form-fieldset-inner {
	display: table-cell;
	vertical-align: middle;
	border-bottom: 1px solid #888;
}
}

/*SP*/
@media screen and (max-width: 767px) {
.sn-m-form-table {
	border-bottom: 1px solid #888;
}
.sn-m-form-table fieldset > span, .sn-m-form-table .sn-m-form-fieldset-inner {
	display: block;
}
.sn-m-form-table fieldset > span{
	border-top: 1px solid #888;
}
.sn-m-form-table legend {
	margin: 0;
}
.sn-m-form-table legend > br{
	display: none;		
}
}

/* ---------------------
	テキスト系
--------------------- */

.sn-m-form input[type="email"], .sn-m-form input[type="number"], .sn-m-form input[type="password"], .sn-m-form input[type="tel"], .sn-m-form input[type="text"] {
	border: 1px solid #888;
	border-radius: 4px;
	display: inline-block;
	line-height: 1.4em;
	font-size: 18px;
	padding: 2px 4px;
	margin:0 8px 8px 8px;
}
/*サイズ*/
.sn-m-form input[type="text"].sn-p-l, .sn-m-form input[type="password"].sn-p-l, .sn-m-form input[type="email"].sn-p-l {
	font-size: 21px;
}
.sn-m-form input[type="text"].sn-p-m, .sn-m-form input[type="password"].sn-p-m, .sn-m-form input[type="email"].sn-p-m {
	font-size: 18px;
}
.sn-m-form input[type="text"].sn-p-s, .sn-m-form input[type="password"].sn-p-s, .sn-m-form input[type="email"].sn-p-s {
	font-size: 14px;
}
/*ラベル*/
.sn-m-form label > input[type="email"], .sn-m-form label > input[type="number"], .sn-m-form label > input[type="password"], .sn-m-form label > input[type="tel"], .sn-m-form label > input[type="text"] {
	margin:0 8px;
}

/*SP*/
@media screen and (max-width: 767px) {
.sn-m-form input[type="email"], .sn-m-form input[type="number"], .sn-m-form input[type="password"], .sn-m-form input[type="tel"], .sn-m-form input[type="text"] {
	width: calc(100% - 16px);
}

.sn-m-form label > input[type="email"], .sn-m-form label > input[type="number"], .sn-m-form label > input[type="password"], .sn-m-form label > input[type="tel"], .sn-m-form label > input[type="text"] {
	margin: 0px 8px 8px 8px;
}
}


/*必須*/
.sn-m-form input[type="email"]:required, .sn-m-form input[type="number"]:required, .sn-m-form input[type="password"]:required, .sn-m-form input[type="tel"]:required, .sn-m-form input[type="text"]:required {
 background-color:#FAE5E5;
}

/*入力済み*/
.sn-m-form input[type="email"]:valid, .sn-m-form input[type="number"]:valid, .sn-m-form input[type="password"]:valid, .sn-m-form input[type="tel"]:valid, .sn-m-form input[type="text"]:valid {
 background-color: #fff;
}

/*エラー*/
.sn-m-form input[type="email"]:invalid:not(:empty), .sn-m-form input[type="number"]:invalid:not(:empty), .sn-m-form input[type="password"]:invalid:not(:empty), .sn-m-form input[type="tel"]:invalid:not(:empty), .sn-m-form input[type="text"]:invalid:not(:empty), .sn-m-form input[type="email"]:out-of-range, .sn-m-form input[type="number"]:out-of-range, .sn-m-form input[type="password"]:out-of-range, .sn-m-form input[type="tel"]:out-of-range, .sn-m-form input[type="text"]:out-of-range {
 background-color:#FAE5E5;
}
/*入力中*/
.sn-m-form input[type="email"]:focus, .sn-m-form input[type="number"]:focus, .sn-m-form input[type="password"]:focus, .sn-m-form input[type="tel"]:focus, .sn-m-form input[type="text"]:focus {
	background-color: #fff;
}
/*ラベルアニメーション*/
.sn-m-form-label-placeholder {
	display: inline-block;
	position: relative;
}
.sn-m-form-label-placeholder input[type="text"], .sn-m-form-label-placeholder input[type="password"], .sn-m-form-label-placeholder input[type="email"] {
	margin-top: 16px;
}
.sn-m-form-label-placeholder input[type="text"] + label, .sn-m-form-label-placeholder input[type="password"] + label, .sn-m-form-label-placeholder input[type="email"] + label {
	color: #888;
	line-height: 0;
	font-weight: normal;
	position: absolute;
	pointer-events: none;
	text-align: left;
	left: 8px;
	top: 2.2em;
	transition: 0.2s ease all;
	-moz-transition: 0.2s ease all;
	-webkit-transition: 0.2s ease all;
}
.sn-m-form-label-placeholder input[type="text"]:focus ~ label, .sn-m-form-label-placeholder input[type="text"]:valid ~ label, .sn-m-form-label-placeholder input[type="password"]:focus ~ label, .sn-m-form-label-placeholder input[type="password"]:valid ~ label, .sn-m-form-label-placeholder input[type="email"]:focus ~ label, .sn-m-form-label-placeholder input[type="email"]:valid ~ label {
 top:0.4em;
 left:4px;
 font-size:12px !important;
 color:#16a085;
}
/* ---------------------
	ラジオボタン＆チェックボックス
--------------------- */
input[type=radio], input[type=checkbox] {
	display: none;
}
.sn-m-form input[type=radio] + label, .sn-m-form input[type=checkbox] + label {
	box-sizing: border-box;
	-webkit-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
	position: relative;
	display: inline-block;
	margin: 0;
	padding: 6px 10px 6px 34px;
	border-radius: 8px;
	vertical-align: baseline;
	cursor: pointer;
}
.sn-m-form input[type=radio] + label:hover, .sn-m-form input[type=checkbox] + label:hover {
	background-color: rgba(228,255,214,0.5);
}
.sn-m-form input[type=radio] + label:after {
	-webkit-transition: opacity 0.2s linear;
	transition: opacity 0.2s linear;
	position: absolute;
	top: 50%;
	left: 13px;
	display: block;
	margin-top: -5px;
	width: 10px;
	height: 10px;
	border-radius: 20px;
	background-color: #16a085;
	content: '';
	opacity: 0;
}
.sn-m-form input[type=radio]:checked + label {
	background-color: #e4ffd6;
}
.sn-m-form input[type=radio]:checked + label:after {
	opacity: 1;
}
.sn-m-form input[type=radio] + label:before {
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
	position: absolute;
	top: 50%;
	left: 8px;
	display: block;
	margin-top: -10px;
	width: 16px;
	height: 16px;
	border: 2px solid #888;
	border-radius: 20px;
	content: '';
	background: #fff;
}
.sn-m-form input[type=checkbox] + label:after {
	-webkit-transition: opacity 0.2s linear;
	transition: opacity 0.2s linear;
	position: absolute;
	top: 50%;
	left: 14px;
	display: block;
	margin-top: -7px;
	width: 5px;
	height: 9px;
	border-right: 3px solid #16a085;
	border-bottom: 3px solid #16a085;
	content: '';
	opacity: 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}
.sn-m-form input[type=checkbox]:checked + label {
	background-color: #e4ffd6;
}
.sn-m-form input[type=checkbox]:checked + label:after {
	opacity: 1;
}
.sn-m-form input[type=checkbox] + label:before {
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
	position: absolute;
	top: 50%;
	left: 8px;
	display: block;
	margin-top: -10px;
	width: 16px;
	height: 16px;
	border: 2px solid #888;
	border-radius: 4px;
	content: '';
	background: #fff;
}
/*disable*/
.sn-m-form input:disabled + label {
	background-color: transparent;
	pointer-events: none;
	color: #888;
}
.sn-m-form input:disabled + label:after {
	border: none;
	background: none;
}
.sn-m-form input:disabled + label:before {
	color: #fff;
	background: #eee;
}
/* ---------------------
	メッセージボックス
--------------------- */

.sn-m-form-messagebox:not(:empty) {
	width: 678px;
	margin: 16px auto;
	padding: 16px;
	box-sizing: border-box;
	text-align: left;
}
.sn-m-form-messagebox:not(:empty).sn-p-success {
	background: #E6FFF2;
}
.sn-m-form-messagebox:not(:empty).sn-p-error {
	background: #FAE5E5;
}

/*SP*/
@media screen and (max-width: 767px) {
.sn-m-form-messagebox:not(:empty) {
	width: 100%;
}
}
/* ---------------------------------------------------------------
	ステップバー
--------------------------------------------------------------- */

.sn-m-stepbar {
	margin: 8px auto 16px auto;
}
.sn-m-stepbar > ol {
	display: table;
	table-layout: fixed;
	width: 100%;
	height: 48px;
	text-align: center;
	overflow: hidden;
	padding: 0;
	margin: 0;
}
.sn-m-stepbar > ol > li {
	display: table-cell;
	position: relative;
	padding: 8px 16px 8px 18px;
	margin: 0;
	background-color: #eee;
	font-weight: bold;
	font-size: 14px;
	color: #000;
	box-sizing: border-box;
	line-height: 1.2em;
	vertical-align: middle;
}
.sn-m-stepbar > ol > li:last-child {
	padding-right: 8px;
}
.sn-m-stepbar > ol > li:first-child {
	padding-left: 8px;
}
.sn-m-stepbar > ol > li:before, .sn-m-stepbar > ol > li:after {
	content: "";
	display: block;
	position: absolute;
	left: -10px;
	border-left: 2px solid #fff;
	background-color: #eee;
	width: 15px;
	height: 25px;
}
.sn-m-stepbar > ol > li:before {
	bottom: 0;
	-webkit-transform: skew(-30deg);
	transform: skew(-30deg);
}
.sn-m-stepbar > ol > li:after {
	top: 0;
	-webkit-transform: skew(30deg);
	transform: skew(30deg);
}
.sn-m-stepbar > ol > li:first-child {
	-webkit-order-top-left-radius: 4px;
	border-top-left-radius: 4px;
	border-bottom-left-radius: 4px;
}
.sn-m-stepbar > ol > li:first-child:before, .sn-m-stepbar > ol > li:first-child:after {
	content: none;
}
.sn-m-stepbar > ol > li:last-child {
	border-top-right-radius: 4px;
	border-bottom-right-radius: 4px;
}
.sn-m-stepbar > ol > li > span {
	display: inline-block;
	position: relative;
}
.sn-m-stepbar > ol > li.current {
	background-color: #1abc9c;
	color: #fff;
}
.sn-m-stepbar > ol > li.current:before, .sn-m-stepbar > ol > li.current:after {
	background-color: #1abc9c;
}
.sn-m-stepbar > ol > li.current > span:before {
	color: #1abc9c;
}

@media screen and (max-width: 767px) {
.sn-m-stepbar {
	margin: 8px auto;
}
.sn-m-stepbar > ol {
	height: 48px;
}
.sn-m-stepbar > ol > li {
	padding: 0 8px 0 4px;
	font-size: 10px;
}
.sn-m-stepbar > ol > li:before, .sn-m-stepbar > ol > li:after {
	left: -6px;
	width: 8px;
	height: 24px;
}
.sn-m-stepbar > ol > li > span:before {
	line-height: 14px;
	height: 14px;
	width: 14px;
	font-size: 11px;
}
.sn-m-stepbar > ol > li:before {
	-webkit-transform: skew(-20deg);
	transform: skew(-20deg);
}
.sn-m-stepbar > ol > li:after {
	-webkit-transform: skew(20deg);
	transform: skew(20deg);
}
}
